<template>
  <div>
    <!-- Header 头部区域 -->
    <div class="search-header">
      <!-- 后退图标 -->
      <van-icon name="arrow-left" color="white" size="18" class="goback" @click="$router.back()" />
      <!-- 搜索组件 -->
      <van-search v-model.trim="kw" placeholder="请输入搜索关键词" background="#007BFF" shape="round" ref="searchRef"
        @input="onInput" />
    </div>

    <!-- 搜索建议 -->
    <div class="sugg-list" v-if="kw.length != 0">
      <div class="sugg-item" v-for="(item, i) in suggestList" :key="i" v-html="item" @click="gotoSearchResult">{{item}}
      </div>
    </div>

    <!-- 搜索历史 -->
    <div class="search-history" v-else>
      <!-- 标题 -->
      <van-cell title="搜索历史">
        <!-- 使用 right-icon 插槽来自定义右侧图标 -->
        <template #right-icon>
          <!-- 在带年纪事件处理函数中，直接将 history 数组清空即可 -->
          <van-icon name="delete" class="search-icon" @click="history = []" />
        </template>
      </van-cell>

      <!-- 历史列表 -->
      <div class="history-list">
        <span class="history-item" v-for="(tag, i) in history" :key="i" @click="gotoSearchResult">{{tag}}</span>
      </div>
    </div>
  </div>
</template>

<script>
  // 按需导入 API 接口
  import {
    getSuggestListAPI
  } from '@/api/searchAPI.js'
  export default {
    name: 'Search',
    data() {
      return {
        // 搜索关键词
        kw: '',
        //延时器的id
        timeId: null,
        // 搜索建议列表
        suggestList: [],
        // 搜索历史
        history: JSON.parse(localStorage.getItem('history') || '[]')
      }
    },
    mounted() {
      const ipt = document.querySelector('input[type=search]')
      ipt && ipt.focus()

    },
    methods: {
      //搜索组件的输入事件
      onInput() {
        // 2. 清除上次的延时器
        clearTimeout(this.timerId)

        // 输入的搜索关键词为空
        if (this.kw.length === 0) {
          // 清空搜索建议的列表数据
          this.suggestList = []
          return
        }

        // 1. 开启延时器，将延时器的 id 存储到 this.timerId 中
        this.timerId = setTimeout(() => {
          this.initSuggestList()
        }, 500)
      },
      // 请求搜索建议列表数据的方法
      async initSuggestList() {
        // 调用 API 接口
        const {
          data: res
        } = await getSuggestListAPI(this.kw)
        if (res.message === 'OK') {
          // 1. 调用 hlightKeywords 方法，对关键词进行高亮处理
          this.hlightKeywords(res.data.options)
          // 为 suggestList 数据赋值
          this.suggestList = res.data.options
          // 把搜索关键词加入到搜索历史中
          const newHistory = this.history.filter(item => item !== this.kw)
          newHistory.unshift(this.kw)
          this.history = newHistory

        }
      },
      // 高亮搜索关键词的方法，形参中的 arr 是搜索建议的数组
      hlightKeywords(arr) {
        // 1. 根据用户输入的 kw，动态创建正则表达式
        const reg = new RegExp(this.kw, 'ig')
        // 循环数组中的每一项
        arr.forEach((item, index) => {
          // 2. 调用字符串的 replace 方法进行关键字的高亮处理
          arr[index] = item.replace(reg, val => {
            return `<span style="color: red; font-weight: bold;">${val}</span>`
          })
        })
      },
      // // 跳转到搜索结果页
      gotoSearchResult(e) {
        // e.currentTarget 是当正在触发事件的那个元素
        // console.log(e.currentTarget.innerText)

        // 1. 获取用户当前点击的搜索建议项的内容
        const kw = e.currentTarget.innerText
        // 2. 通过编程式导航 API，跳转到搜索结果页
        this.$router.push('/search/' + kw)
      }
    },
    watch: {
      // 监视历史记录的变化
      history(newVal) {
        localStorage.setItem('history', JSON.stringify(newVal))
      }
    }
  }
</script>

<style lang="less" scoped>
  .search-icon {
    font-size: 16px;
    line-height: inherit;
  }

  .history-list {
    padding: 0 10px;

    .history-item {
      display: inline-block;
      font-size: 12px;
      padding: 8px 14px;
      background-color: #efefef;
      margin: 10px 8px 0px 8px;
      border-radius: 10px;
    }
  }

  .search-header {
    height: 46px;
    display: flex;
    align-items: center;
    background-color: #007bff;
    overflow: hidden;

    // 后退按钮
    .goback {
      padding-left: 14px;
    }

    // 搜索组件
    .van-search {
      flex: 1;
    }
  }

  .sugg-list {
    .sugg-item {
      padding: 0 15px;
      border-bottom: 1px solid #f8f8f8;
      font-size: 14px;
      line-height: 50px;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }
  }
</style>
